# Proyecto Final

Fiorella Delgado León, Jonathan Guzmán Araya, Mariano Muñoz Masís fiorelladelgado53@gmail.com, jonathana1196@gmail.com, marianomm1301@gmail.com Área Académica de Ingeniería en Computadores
Instituto Tecnológico de Costa Rica, Cartago, Costa Rica, 2021

Resumen—Este documento presenta los resultados del proyecto final del curso.

Palabras clave—FPGA

#### I. Introducción

El procesador ARM es un componente clave de muchos sistemas integrados. El primer ARM se introdujo en 1985, bajo el nombre de Acorn RISC Machine (luego renombrado Advanced RISC Machine). La relativa simplicidad de los procesadores ARM los hizo adecuados para aplicaciones de bajo consumo permitiendo así su actual amplia adopción. ARM es inusual en el sentido de que no vende proesadores directamente, si no que autoriza a otras compañías a construir sus diseños de procesadores, a menudo como parte de un sistema en chip más grande, por ejemplo: Samsung, Altera, Apple, Qualcomm construyen procesadores ARM, ya sea utilizando microarquitecturas compradas en ARM o microarquitecturas desarrolladas bajo licencia ARM [1].

La arquitectura de un computador es la visión del programador de una computadora, esta arquitectura está definida por un conjunto de instrucciones (lenguaje) y ubicaciones de los operandos (registros y memoria) [2].

El primer paso para entender la arquitectura de un computadora es entender su lenguaje, las palabras en el lenguaje de una computadora son llamadas instrucciones, el vocabulario de una computadora es llamado conjunto de instrucciones, de manera que todos los programas en esta computadora utilizan el mismo conjunto de instrucciones, incluso las más complejas.

## I-A. Tipos de instrucciones y su codificación

Las instrucciones de una computadora indican el tipo de operación a realizar y los operandos a utilizar, los operandos vienen desde la memoria a los registros y de estos a las instrucciones. Las computadoras solo comprender 1's y 0's, es por esto que las instrucciones son codificadas en como números binarios en un formato llamado lenguaje máquina [2].

El lenguaje Ensamblador es la representación humana de este lenguaje máquina, cada instrucción en Ensamblador especifica tanto el tipo de instrucción como sus operandos. En ARMv4 existen cuatro formatos principales de instrucciones: data procesing, memory, branch y miscellaneous. Este pequeño número de formatos permite cierta regularidad entre las instrucciones, y por lo tanto, un hardware de decodificador simple.

*I-A1. Data Procesing Instructions:* Las instrucciones de procesamiento de datos tienen dos registros fuentes, donde el segundo puede ser un inmediato y el tercer registro que es el destino.



Figura 1. Codificación de instrucciones de procesamiento de datos [2]

Los 32 bits de estos tipos de instrucciones tienen bits específicos asignados para una serie de datos que tienen que ir en esos bits para especificar el tipo de instrucción y que hacer con los mismos, esto se detalla a continuación.

- cond: ejecución condicional basada en las banderas que se especificaron en la Tabla VI.
- op: código del tipo operación a realizar.
- funct: código de instrucción a realizar, a su vez en las instrucciones de procesamiento de datos este se divide en tres partes.
  - I: especifica si se está o no trabajando con un inmediato.
  - cmd: código de la instrucción a realizar.
  - S: si las banderas se tienen que guardar o no.
- Rn: registro para el operando 1.
- Rd: registro destino donde se guardará el resultado de los operandos.
- Src2: en las instrucciones de procesamiento puede presentar tres casos.
  - Inmediato
    - rot: rotación circular de 8 bits para armar números de 32 bits.
    - o imm8: inmediato, este no puede ser más de 255.
  - · Registro
    - o shamt5: constante de desplazamiento.
    - o sh: indica el tipo de desplazamiento a realizar como se observa en la Tabla I.
    - o 0: bit por defecto según la instrucción.
    - o Rm: registro para el operando 2.
  - Registro con desplazamiento
    - o Rs: registro de desplazamiento.

- o 0: bit por defecto según la instrucción.
- o sh: indica el tipo de desplazamiento a realizar como se observa en la Tabla I.
- o 1: bit por defecto según el tipo de instrucción.
- o Rm: registro para el operando 2.

| Instrucción | sh       | Operación              |  |  |  |
|-------------|----------|------------------------|--|--|--|
| LSL         | 002      | Logical left shift     |  |  |  |
| LSR         | $01_{2}$ | Logical right shift    |  |  |  |
| ASR         | $10_{2}$ | Arithmetic shift right |  |  |  |
| ROR         | $11_{2}$ | Rotate right           |  |  |  |
| Cuadro I    |          |                        |  |  |  |

Código de operación de sh

*I-A2. Memory Instructions:* Las instrucciones de memoria utilizan un formato similar al que utilizan las instrucciones de procesamiento de datos, con las mimas seis divisiones, sin embargo, utilizan un código de operación diferente al utilizado en las instrucciones de procesamiento de datos tal y como se muestra en la Figura 2.

|       |          |        | Men   | nory  |      | ÷ .   | Immediat | е      | 11:0  |     |
|-------|----------|--------|-------|-------|------|-------|----------|--------|-------|-----|
| 31:28 | 27:26    | 25:20  | 19:16 | 15:12 | 11:0 | I = ( | )        | ir     | nm12  |     |
| cond  | op<br>01 | PUBW L | Rn    | Rd    | Src2 |       |          | 11:7   | 6:5 4 | 3:0 |
|       | _        | funct  |       |       |      | Ī = 1 | Register | shamt5 | sh 1  | Rm  |

Figura 2. Codificación de instrucciones de memoria [2]

- cond: ejecución condicional basada en las banderas que se especificaron en la Tabla VI.
- op: código del tipo operación a realizar.
- funct: código de instrucción a realizar, a su vez está compuesto de seis bits de control.
  - I
     U: Los bits I
     (inmediato) y U (sumar) determinan si el desplazamiento es inmediato o de registro y si se debe sumar o restar de acuerdo a la Tabla II.
  - P W: Los bits P (pre-índice) y W (escritura) especifican el modo de índice de acuerdo a la Tabla III.
  - B L: Los bits L (carga) y B (byte) especifican el tipo de operación de memoria de acuerdo a la Tabla IV
- Rn: registro para el operando 1.
- Rd: registro destino donde se guardará el resultado de los operandos.
- Src2: en las instrucciones de memoria puede presentar dos casos.
  - Inmediato
    - o imm12: desplazamiento inmediato sin signo.
  - Registro
    - o shamt5: constante de desplazamiento.
    - sh: indica el tipo de desplazamiento a realizar como se observa en la Tabla I.
    - o 1: bit por defecto según la instrucción.
    - o Rm: registro para el operando 2.
- *I-A3. Branch Instructions:* Las instrucciones de bifurcación utilizan un desplazamiento de 24 bits, por lo que los 32 bits quedan divididos como se muestra en la Figura 3.

| Bit       | $\overline{I}$           | U      |  |
|-----------|--------------------------|--------|--|
| 0         | Desplazamiento inmediato | Restar |  |
| 1         | Registro                 | Sumar  |  |
| Cuadro II |                          |        |  |

Instrucciones de control para  $\overline{I}$  y U

| P | W          | Modo         |  |  |  |  |
|---|------------|--------------|--|--|--|--|
| 0 | 0          | Pos-índice   |  |  |  |  |
| 0 | 1          | No soportado |  |  |  |  |
| 1 | 0          | Offset       |  |  |  |  |
| 1 | 1          | Pre-índice   |  |  |  |  |
|   | Cuadro III |              |  |  |  |  |

INSTRUCCIONES DE CONTROL PARA P Y W

| L         | В | Instrucción |  |  |  |
|-----------|---|-------------|--|--|--|
| 0         | 0 | STR         |  |  |  |
| 0         | 1 | STRB        |  |  |  |
| 1         | 0 | LDR         |  |  |  |
| 1         | 1 | LDRB        |  |  |  |
| Cuadro IV |   |             |  |  |  |

INSTRUCCIONES DE CONTROL PARA L Y B

- cond: ejecución condicional basada en las banderas que se especificaron en la Tabla VI.
- op: código del tipo operación a realizar.
- funct: código de instrucción a realizar.
  - 1L: su tamaño siempre es de 2 bits y el MSB siempre es 1, mientras que el LSB indica el tipo de bifurcación a realizar.
- imm24: se utiliza para especificar la dirección de una dirección de instrucción relativa a PC + 8.



Figura 3. Codificación instrucciones de bifurcación [2]

*I-A4. Miscellaneous Instructions:* El conjunto de instrucciones de ARMv4 tiene otro grupo que se detalla en la Tabla V.

Las instrucciones ARM opcionalmente establecen indicadores de condición en función del resultado Las instrucciones posteriores se ejecutan condicionalmente, dependiendo del estado de esos indicadores, también llamados indicadores de estado que se observan en la Tabla VI.

Estas banderas se activan dependiendo del tipo de instrucción que se esté ejecutando, en la Tabla VII se detallan las instrucciones y los tipos de banderas que estos activarían.

La ALU establece estos indicadores y se mantienen en los cuatro bits superiores del CPSR de32 bits tal y como se muestra en la Figura, mientras que los cinco bits menos significativos son los bits de modo, esto es porque un procesador ARM puede operar en una serie de modos de ejecución con diferentes niveles de privilegios. Los diferentes modos permiten que excepciones tomen lugar sin dañar el estado en que se encuentra. Estos modos están especificados en la parte

| Instrucciones                 | Descripción                                 | Propósito                                                                                                       |
|-------------------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| LDM, STM                      | cargar/guardar múltiple                     | Guardar y recuperar regis-<br>tros en llamadas de subru-<br>tina                                                |
| SWP, SWPB                     | Intercambiar byte                           | Carga atómica y almace-<br>namiento para sincroniza-<br>ción de procesos                                        |
| LDRT, LDRBT,<br>STRT, STRBT   | cargar/guardar<br>palabra/byte con traslado | Permitir que el sistema<br>operativo acceda a la me-<br>moria en el espacio de me-<br>moria virtual del usuario |
| SWI                           | Interrupción de software                    | Crear una excepción, que<br>a menudo se usa para lla-<br>mar al sistema operativo                               |
| CDP, LDC,<br>MCR, MRC,<br>STC | Acceso de coprocesador                      | Comunicarse con coprocesador opcional                                                                           |
| MRS, MSR                      | Mover desde/a registro de estado            | Guardar el registro de es-<br>tado durante las excepcio-<br>nes                                                 |

Cuadro V INSTRUCCIONES MISCELÁNEAS

| Bandera | Nombre         | Descripción                               |
|---------|----------------|-------------------------------------------|
| N       | Negativo       | La instrucción resulta negativa si el bit |
|         |                | 31 del resultado es 1                     |
| Z       | Cero           | El resultado es 0                         |
| С       | Acarreo        | La instrucción provoca acarreo            |
| V       | Desbordamiento | La instrucción causa desbordamiento       |
|         |                | Cuadro VI                                 |

BANDERAS

baja del CPSR como se muestra en la Figura 4y se detallan en Tabla VIII.

|    |     |      |    | CPSR |   |   |       |    |   |
|----|-----|------|----|------|---|---|-------|----|---|
| 31 | 30  | 29   | 28 |      | 4 | 3 | 2     | 1  | 0 |
| N  | Z   | С    | V  |      |   | M | l[4   | :0 | ] |
| _  | 4 t | oits |    |      | _ | Ę | 5 bit | s  |   |

Figura 4. Bits de las banderas [2]

## I-B. Registros

Las instrucciones

## I-C. Memoria

## II. SISTEMA DESARROLLADO

Para el desarrollo de este proyecto, se realizó la implementación de una micro arquitectura, utilizando un procesador ARMv4, para descifrar el texto introducido (el cual estará cifrado) mediante uno de los tres algoritmos de descifrado, por medio del lenguaje System Verilog.

## III. RESULTADOS

## IV. ANÁLISIS DE RESULTADOS

#### V. CONCLUSIONES

Al desarrollar este proyecto, se obtuvieron las siguientes conclusiones:

| Tipo       | Instrucciones                   | Banderas   |  |  |
|------------|---------------------------------|------------|--|--|
| Add        | ADDS, ADCS                      | N, Z, C, V |  |  |
| Subtract   | SUBS, SBCS, RSBS, RSCS          | N, Z, C, V |  |  |
| Compare    | CMP, CMN                        | N, Z, C, V |  |  |
| Shifts     | ASRS, LSLS, LSRS, RORS, RRXS    | N, Z, C    |  |  |
| Logical    | ANDS, ORRS, EORS, BICS          | N, Z, C    |  |  |
| Test       | TEQ, TST                        | N, Z, C    |  |  |
| Move       | MOVS, MVNS                      | N, Z, C    |  |  |
| Multiply   | MULS, MLAS, SMLALS, SMULLS, UM- | N, Z       |  |  |
|            | LALS, UMULLS                    |            |  |  |
| Cuadro VII |                                 |            |  |  |

INSTRUCCIONES QUE ACTIVAN LAS BANDERAS

| $CPSR_{4:0}$ |
|--------------|
| 10000        |
| 10011        |
| 10111        |
| 11011        |
| 10010        |
| 10001        |
|              |

Cuadro VIII MODOS DEL PROCESADOR

## VI. BIBLIOGRAFÍA

#### REFERENCIAS

- [1] J. Gomar. (2018, Diciembre) Qué es proce-ARM sador v como funciona. Profesional review. [Online]. Available: https://www.profesionalreview.com/2018/12/05/ que-es-procesador-arm-como-funciona/
- [2] D. M. H. Sarah L. Harris, Digital Design and Computer Architecture. Morgan Kauffmann, 2010.